草庐IT

java - GraphQL 实现 Java

全部标签

go - 为什么直接实现的接口(interface)上的这种类型断言会失败?

我正在与Go的类型断言机制作斗争。在下面的示例中,Qux.(Bar)的类型断言失败。为什么在Qux上直接实现DoBar()没有填充Bar接口(interface)?主要包import("fmt")typeNameableinterface{Name()string}typeFoointerface{NameableDoFoo()string}typeBarinterface{NameableDoBar()string}typebarstruct{namestring}func(bbar)Name()string{returnb.name}//Quxembedsbarandisexpec

go - 填充作为参数给出的接口(interface)类型的一部分(例如,为数据库/sql 实现 ScanAll)

我们如何实现一个函数,该函数将返回SQL查询产生的所有行并将它们转换为dest这是一个接口(interface)数组(可能无法像Scan一样工作)?我假设目标数组必须作为函数的参数给出。但是,我仍然不知道我应该如何完成实现:funcGetAll(querystring,destinterface{})error{rows,err:=s.db.Query(query)iferr!=nil{returnerr}deferrows.Close()forrows.Next(){vardestRow???/*donothaveatype.usingreflect.TypeOf(dest).Ele

go - 获取变量\"$address\"不能是非输入类型\"String!\in go-graphql

我已经使用graphql-go库在go中成功设置了一个GraphQL服务器。但是,在进行查询时传递查询参数时,我似乎遇到了错误。所以我有一个名为emails的查询,它将address作为参数并查询数据库以返回与给定address关联的所有电子邮件的结果.当我直接传递address参数时,一切似乎都很完美,正如您从这张图片中看到的:但是,当我向它传递查询参数时,它似乎不起作用,如下所示:我不认为这两个语句应该给出相同的结果。然而,情况似乎并非如此。有人可以帮助我理解为什么会出现这些错误吗?这是我的代码packagemainimport("log""net/http""github.com

go - 当字段实现 UnmarshalJSON 时,Unmarshal 嵌入式字段指针会出现困惑

我有一个struct,它嵌入了一个指向另一个struct的嵌入式指针。当我使用默认的json.Unmarshal行为时,它工作得很好。但是当我为embeddedstruct的类型实现UnmarshalJSON而不是外部struct,然后使用空指针解引用进行panic。如果我也为外部struct类型实现UnmarshalJSON,那么它就可以工作。但是,外部结构有许多字段,我宁愿不必手动解码。为什么在一个而不是另一个上实现UnmarshalJSON会导致panic?有没有办法在不为外部类型实现UnmarshalJSON的情况下让它工作?如果没有,是否有更简单/更少手动的方法来为外部类型实

go - "graphql.NewList(type)"是做什么的?

事实证明,graphql-go的帮助文档对初学者不友好。我只是想知道.NewList()在以下代码中做了什么:Type:graphql.NewList(types.Workouts) 最佳答案 表示数组类型Listsworkinasimilarway:WecanuseatypemodifiertomarkatypeasaList,whichindicatesthatthisfieldwillreturnanarrayofthattype.Intheschemalanguage,thisisdenotedbywrappingthety

go - 如何实现 goroutines 的管道?

我需要一些帮助来了解如何使用管道将数据从一个goroutine传输到另一个goroutine。我读了golangblogpostonpipeline,我理解了但不能完全付诸行动,因此想到向社区寻求帮助。现在,我想出了这个丑陋的代码(Playground):packagemainimport("fmt""sync""time")funcmain(){wg:=sync.WaitGroup{}ch:=make(chanint)fora:=0;a问题我想使用管道或任何正确的方式来做这件事。此外,博文中显示的管道不适用于goroutines,因此我无法自己完成。在现实生活中,func1和func

go - 实例化具有不同函数签名的对象时函数实现的差异

在函数实现中遇到了以下差异。示例1返回指针和示例2返回实际对象背后的原因是什么?typeMyInterfaceinterface{Func(paramint)float64//justrandomsignature}//MyInterfaceImplimplementsMyInterfacetypeMyInterfaceImplstruct{}//actualimplementationfunc(myObj*MyInterfaceImpl)Func(paramint)float64{returnfloat64(param)}例1:函数返回接口(interface)时返回指向MyInte

go - 使用 xml.NewDecoder(xmlFile) 在 Go/Golang 中解析大型 XML 文件时如何实现进度计数器?

我按照本网站上的示例编写了一些代码来解析大型XML文件(>3GB):https://blog.singleton.io/posts/2012-06-19-parsing-huge-xml-files-with-go/想法是创建decoder:=xml.NewDecoder(xmlFile),然后用decoder.Token()遍历文件,同时检查所有xml.StartElement。只要找到正确的元素,就会使用decoder.DecodeElement()对其进行解码。一切都很好。我现在喜欢的是一种向用户显示进度的方法。类似于“x%的文件已处理”。我知道如何获取XML的文件大小:Howt

go - 实现并发的失败尝试

我很难让go并发正常工作。我正在处理从XML数据源加载的数据。将数据加载到内存后,我循环遍历XML元素并执行操作。加并发前的代码已经过测试,可以正常使用,我认为不会对加并发有任何影响。我有2次失败的并发实现尝试,两次都具有不同的输出。我使用锁定是因为我不想进入竞争状态。对于这个实现,它永远不会进入goroutine。varmusync.Mutex//lengthis197Kfori:=0;i对于此使用waitGroups的实现,发生运行时内存不足varmusync.Mutexvarwgsync.WaitGroup//lengthis197Kfori:=0;i我不太确定发生了什么,需要一

go - 我应该为每个查询或其在 GraphQL 中的所有字段创建解析器吗?

我对使用GraphQL很感兴趣,而且我刚刚开始尝试使用它。在GraphQL中tutorial,可以看到下面的引用:EachfieldinaGraphQLschemaisbackedbyaresolver.但是如果你看gqlgen(这是一个用于构建GraphQL服务器的golang库)todoexample使用以下架构:...typeMyQuery{todo(id:ID!):TodolastTodo:Todotodos:[Todo!]!}typeMyMutation{createTodo(todo:TodoInput!):Todo!updateTodo(id:ID!,changes:Ma